// import fs from "file-saver";
// import XLSX from "xlsx";

// export function exportExcel(
//   json: Array<Object>,
//   fields: Object,
//   filename = ".xlsx"
// ) {
//   //导出xlsx
//   json.forEach((item: { [x: string]: any }) => {
//     for (const i in item) {
//       if (fields.hasOwnProperty(i)) {
//         if (isValidKey(i, fields)) {
//           item[fields[i]] = item[i];
//         }
//       }
//       delete item[i]; //删除原先的对象属性
//     }
//   });
//   const sheetName = filename; //excel的文件名称
//   const wb = XLSX.utils.book_new(); //工作簿对象包含一SheetNames数组，以及一个表对象映射表名称到表对象。XLSX.utils.book_new实用函数创建一个新的工作簿对象。
//   const ws = XLSX.utils.json_to_sheet(json, { header: Object.values(fields) }); //将JS对象数组转换为工作表。
//   wb.SheetNames.push(sheetName);
//   wb.Sheets[sheetName] = ws;
//   const defaultCellStyle = {
//     font: { name: "Verdana", sz: 13, color: "FF00FF88" },
//     fill: { fgColor: { rgb: "FFFFAA00" } },
//   }; //设置表格的样式
//   const wopts: object = {
//     bookType: "xlsx",
//     bookSST: false,
//     type: "binary",
//     cellStyles: true,
//     defaultCellStyle: defaultCellStyle,
//     showGridLines: false,
//   }; //写入的样式
//   const wbout: any = XLSX.write(wb, wopts);
//   const blob = new Blob([s2ab(wbout)], { type: "application/octet-stream" });
//   fs.saveAs(blob, filename + ".xlsx");
// }

// export function isValidKey(
//   key: string | number | symbol,
//   object: object
// ): key is keyof typeof object {
//   return key in object;
// }

// const s2ab = (s: string) => {
//   let buf: ArrayBuffer | any;
//   if (typeof ArrayBuffer !== "undefined") {
//     buf = new ArrayBuffer(s.length);
//     const view = new Uint8Array(buf);
//     for (let i = 0; i != s.length; ++i) view[i] = s.charCodeAt(i) & 0xff;
//     return buf;
//   } else {
//     buf = new Array(s.length);
//     for (let i = 0; i != s.length; ++i) buf[i] = s.charCodeAt(i) & 0xff;
//     return buf;
//   }
// };
